API: gdk_drawable_get_visible_region => gdk_window_get_visible_region
authorBenjamin Otte <otte@redhat.com>
Wed, 6 Oct 2010 21:42:45 +0000 (23:42 +0200)
committerBenjamin Otte <otte@redhat.com>
Thu, 2 Dec 2010 19:17:28 +0000 (20:17 +0100)
Also get rid of the GdkDrawable vfunc.

gdk/gdkdraw.c
gdk/gdkdrawable.h
gdk/gdkwindow.c
gdk/gdkwindow.h

index df9762bf2d34a290158aaf8416ccca9266ff9ebc..77b2936ce64e54f3931e78c53e48b1b89af069f8 100644 (file)
@@ -50,26 +50,6 @@ gdk_drawable_init (GdkDrawable *drawable)
 {
 }
 
-/**
- * gdk_drawable_get_visible_region:
- * @drawable: a #GdkDrawable
- * 
- * Computes the region of a drawable that is potentially visible.
- * This does not necessarily take into account if the window is
- * obscured by other windows, but no area outside of this region
- * is visible.
- * 
- * Returns: a #cairo_region_t. This must be freed with cairo_region_destroy()
- *          when you are done.
- **/
-cairo_region_t *
-gdk_drawable_get_visible_region (GdkDrawable *drawable)
-{
-  g_return_val_if_fail (GDK_IS_DRAWABLE (drawable), NULL);
-
-  return GDK_DRAWABLE_GET_CLASS (drawable)->get_visible_region (drawable);
-}
-
 /**
  * _gdk_drawable_ref_cairo_surface:
  * @drawable: a #GdkDrawable
index 1c619a89088a4464f7aba192a28011118d2a015e..b8799e343de7f36d52b00226f7a2dd26a2138d29 100644 (file)
@@ -62,8 +62,6 @@ struct _GdkDrawableClass
 {
   GObjectClass parent_class;
   
-  cairo_region_t*   (*get_visible_region) (GdkDrawable  *drawable);
-
   cairo_surface_t *(*ref_cairo_surface) (GdkDrawable *drawable);
 
   cairo_surface_t * (*create_cairo_surface) (GdkDrawable *drawable,
@@ -83,8 +81,6 @@ struct _GdkDrawableClass
 
 GType           gdk_drawable_get_type     (void) G_GNUC_CONST;
 
-cairo_region_t *gdk_drawable_get_visible_region (GdkDrawable *drawable);
-
 G_END_DECLS
 
 #endif /* __GDK_DRAWABLE_H__ */
index 5523d07a6261b1803d71f6c0e64bbe7fd0e9acb8..e3d401368f8034dbcff66dcd17bae55435ee2f63 100644 (file)
@@ -225,8 +225,6 @@ static cairo_surface_t *gdk_window_create_cairo_surface (GdkDrawable *drawable,
                                                         int height);
 static void             gdk_window_drop_cairo_surface (GdkWindowObject *private);
 
-static cairo_region_t*   gdk_window_get_visible_region     (GdkDrawable *drawable);
-
 static void gdk_window_free_paint_stack (GdkWindow *window);
 
 static void gdk_window_init       (GdkWindowObject      *window);
@@ -382,7 +380,6 @@ gdk_window_class_init (GdkWindowObjectClass *klass)
 
   drawable_class->ref_cairo_surface = gdk_window_ref_cairo_surface;
   drawable_class->create_cairo_surface = gdk_window_create_cairo_surface;
-  drawable_class->get_visible_region = gdk_window_get_visible_region;
 
   klass->create_surface = _gdk_offscreen_window_create_surface;
 
@@ -3560,10 +3557,26 @@ gdk_window_get_clip_region (GdkWindow *window)
   return result;
 }
 
-static cairo_region_t*
-gdk_window_get_visible_region (GdkDrawable *drawable)
+/**
+ * gdk_window_get_visible_region:
+ * @window: a #GdkWindow
+ * 
+ * Computes the region of the @window that is potentially visible.
+ * This does not necessarily take into account if the window is
+ * obscured by other windows, but no area outside of this region
+ * is visible.
+ * 
+ * Returns: a #cairo_region_t. This must be freed with cairo_region_destroy()
+ *          when you are done.
+ **/
+cairo_region_t *
+gdk_window_get_visible_region (GdkWindow *window)
 {
-  GdkWindowObject *private = (GdkWindowObject*) drawable;
+  GdkWindowObject *private;
+  
+  g_return_val_if_fail (GDK_IS_WINDOW (window), NULL);
+
+  private = (GdkWindowObject*) window;
 
   return cairo_region_copy (private->clip_region);
 }
@@ -4511,7 +4524,7 @@ gdk_window_invalidate_maybe_recurse_full (GdkWindow            *window,
       private->window_type == GDK_WINDOW_ROOT)
     return;
 
-  visible_region = gdk_drawable_get_visible_region (window);
+  visible_region = gdk_window_get_visible_region (window);
   cairo_region_intersect (visible_region, region);
 
   tmp_list = private->children;
index f600c76ae0eaeea3aadaac81485b747293bc2b1b..4e408ca86ab10734451443c410db36fc3b79e142 100644 (file)
@@ -681,6 +681,8 @@ void          gdk_window_set_geometry_hints (GdkWindow          *window,
 void          gdk_set_sm_client_id          (const gchar        *sm_client_id);
 
 cairo_region_t *gdk_window_get_clip_region  (GdkWindow          *window);
+cairo_region_t *gdk_window_get_visible_region(GdkWindow         *window);
+
 
 void         gdk_window_begin_paint_rect   (GdkWindow          *window,
                                             const GdkRectangle *rectangle);